<script lang="ts">
	import { Checkbox } from '$lib/components/ui/checkbox';
	import { Input } from '$lib/components/ui/input';
	import Label from '$lib/components/ui/label/label.svelte';
	import * as Select from '$lib/components/ui/select';
	import { Textarea } from '$lib/components/ui/textarea';
	import { SETTING_CONFIG_DEFAULT, SETTING_CONFIG_INFO } from '$lib/constants/settings-config';
	import { supportsVision } from '$lib/stores/server.svelte';
	import type { Component } from 'svelte';

	interface Props {
		fields: SettingsFieldConfig[];
		localConfig: SettingsConfigType;
		onConfigChange: (key: string, value: string | boolean) => void;
		onThemeChange?: (theme: string) => void;
		isMobile?: boolean;
	}

	let { fields, localConfig, onConfigChange, onThemeChange, isMobile = false }: Props = $props();
</script>

{#each fields as field (field.key)}
	<div class="space-y-2">
		{#if field.type === 'input'}
			<Label for={field.key} class="block text-sm font-medium">
				{field.label}
			</Label>

			<Input
				id={field.key}
				value={String(localConfig[field.key] || '')}
				onchange={(e) => onConfigChange(field.key, e.currentTarget.value)}
				placeholder={`Default: ${SETTING_CONFIG_DEFAULT[field.key] || 'none'}`}
				class={isMobile ? 'w-full' : 'max-w-md'}
			/>
			{#if field.help || SETTING_CONFIG_INFO[field.key]}
				<p class="mt-1 text-xs text-muted-foreground">
					{field.help || SETTING_CONFIG_INFO[field.key]}
				</p>
			{/if}
		{:else if field.type === 'textarea'}
			<Label for={field.key} class="block text-sm font-medium">
				{field.label}
			</Label>

			<Textarea
				id={field.key}
				value={String(localConfig[field.key] || '')}
				onchange={(e) => onConfigChange(field.key, e.currentTarget.value)}
				placeholder={`Default: ${SETTING_CONFIG_DEFAULT[field.key] || 'none'}`}
				class={isMobile ? 'min-h-[100px] w-full' : 'min-h-[100px] max-w-2xl'}
			/>
			{#if field.help || SETTING_CONFIG_INFO[field.key]}
				<p class="mt-1 text-xs text-muted-foreground">
					{field.help || SETTING_CONFIG_INFO[field.key]}
				</p>
			{/if}
		{:else if field.type === 'select'}
			{@const selectedOption = field.options?.find(
				(opt: { value: string; label: string; icon?: Component }) =>
					opt.value === localConfig[field.key]
			)}

			<Label for={field.key} class="block text-sm font-medium">
				{field.label}
			</Label>

			<Select.Root
				type="single"
				value={localConfig[field.key]}
				onValueChange={(value) => {
					if (field.key === 'theme' && value && onThemeChange) {
						onThemeChange(value);
					} else {
						onConfigChange(field.key, value);
					}
				}}
			>
				<Select.Trigger class={isMobile ? 'w-full' : 'max-w-md'}>
					<div class="flex items-center gap-2">
						{#if selectedOption?.icon}
							{@const IconComponent = selectedOption.icon}
							<IconComponent class="h-4 w-4" />
						{/if}

						{selectedOption?.label || `Select ${field.label.toLowerCase()}`}
					</div>
				</Select.Trigger>
				<Select.Content>
					{#if field.options}
						{#each field.options as option (option.value)}
							<Select.Item value={option.value} label={option.label}>
								<div class="flex items-center gap-2">
									{#if option.icon}
										{@const IconComponent = option.icon}
										<IconComponent class="h-4 w-4" />
									{/if}
									{option.label}
								</div>
							</Select.Item>
						{/each}
					{/if}
				</Select.Content>
			</Select.Root>
			{#if field.help || SETTING_CONFIG_INFO[field.key]}
				<p class="mt-1 text-xs text-muted-foreground">
					{field.help || SETTING_CONFIG_INFO[field.key]}
				</p>
			{/if}
		{:else if field.type === 'checkbox'}
			{@const isDisabled = field.key === 'pdfAsImage' && !supportsVision()}
			<div class="flex items-start space-x-3">
				<Checkbox
					id={field.key}
					checked={Boolean(localConfig[field.key])}
					disabled={isDisabled}
					onCheckedChange={(checked) => onConfigChange(field.key, checked)}
					class="mt-1"
				/>

				<div class="space-y-1">
					<label
						for={field.key}
						class="cursor-pointer text-sm leading-none font-medium {isDisabled
							? 'text-muted-foreground'
							: ''}"
					>
						{field.label}
					</label>

					{#if field.help || SETTING_CONFIG_INFO[field.key]}
						<p class="text-xs text-muted-foreground">
							{field.help || SETTING_CONFIG_INFO[field.key]}
						</p>
					{:else if field.key === 'pdfAsImage' && !supportsVision()}
						<p class="text-xs text-muted-foreground">
							PDF-to-image processing requires a vision-capable model. PDFs will be processed as
							text.
						</p>
					{/if}
				</div>
			</div>
		{/if}
	</div>
{/each}
